package maxSubArray53;

public class MaxSubArray {

    public static void main(String[] args) {
        MaxSubArray maxSubArray = new MaxSubArray();
        int[] a = {-2, 1, -3, 4, -1, 2, 1, -5, 4};
        System.out.println(maxSubArray.maxSubArray(a));
    }


    public int maxSubArray(int[] nums) {

        int res = nums[0]; //最大值初始化
        int sums = 0; //和参数初始化
        for (int i = 0; i < nums.length; i++) {
            if(sums > 0){//大于0就接着往后加
                sums += nums[i];
            }else{//小于零则把当前值替换成和值作为初始值
                sums = nums[i];
            }
            res = Math.max(res, sums);
        }

        return res;
    }
}
